草庐IT

c++ - std::string 和 UTF-8 编码的 unicode

全部标签

单引号或双引号字符串的 ruby​​ 编码约定

我环顾四周,但找不到关于如何对字符串使用引号的约定。我知道两者之间的区别,但到处都能看到带有双引号的好代码,其中单引号就足够了。因此,我无法识别任何模式。我问这个是因为我想开始为开源做贡献,我想从一开始就养成一个好习惯。我宁愿尽可能使用单引号,也是为了增强我对两者之间差异的信心。 最佳答案 你可能已经知道的:单引号适用于简单的字符串。如果您需要计算字符串中的任何内容,您需要使用双引号。有nosignificantperformancedifference.使用双引号很有用,这样您就可以使用撇号而不必担心在字符串中转义它们,从而使字符

ruby-on-rails - 如何检查字符是否为utf-8

如何通过ruby|ror查看字符集是否为utf-8编码? 最佳答案 检查UTF-8有效性对于大多数多字节编码,可以通过编程方式检测无效字节序列。由于Ruby默认将所有字符串视为UTF-8,您可以检查字符串是否以有效的UTF-8格式给出:#encoding:UTF-8#-------------------------------------------str="Partlyvalid\xE4UTF-8encoding:äöüß"str.valid_encoding?#=>falsestr.scrub('').valid_encodi

ruby: unicode字符十进制值到\uXXXX转换? .ord 方法不起作用

我正在尝试使用unicode字符,而字符串的.ord方法提供的信息对我没有帮助。我习惯于使用“\uXXXX”这样的代码。ruby-1.9.3-p0:119>form[0]=>"כ"ruby-1.9.3-p0:120>form[0].ord=>1499ruby-1.9.3-p0:121>puts"\u1499"ᒙ...:-(.ord产生的值似乎对应于此处提到的“小数点”:http://www.i18nguy.com/unicode/hebrew.html我不知道如何使用这些值。我如何从该字符获取\uXXXX代码?谢谢 最佳答案 \u语

ruby - 带有 RVM 的 Ruby 1.9.3 IRB 中的 Unicode 字符

更新:我发现几乎完全一样similarquestion,但它的先决条件略有不同,因此帮助不大。给定:MacOSLion10.7.3rvm1.14.2ruby1.9.3p194(2012-04-20修订版35410)[x86_64-darwin11.3.0]Ruby使用以下行安装:rvm安装1.9.3--with-readline-dir=/usr/local/Cellar/readline/6.2.2/当我启动irb或railsc并开始输入unicode字符时,我得到:\U+FFD0\U+FFBF\U+FFD1\U+FFD0\U+FFB8\U+FFD0\U+FFBC\U+FFD0\U+

ruby - 重复给 "string" "x"次的方法

我正在尝试编写一个方法,该方法将采用两个参数,一个用于字符串,另一个用于将重复的次数。这是我的代码:defrepeat(text,c=2)c.timesdoprinttextendendrepeat("hi")这里的问题是,我希望结果是“hihi”我试过“puts”但是开始了一个新行......[printtext"+"text]也不起作用...感谢您的帮助! 最佳答案 你的问题不清楚。如果您只想打印重复n次的文本,请使用String#*defrepeat(text,n=2)printtext*nend您的示例结果说您想要"hihi

ruby-on-rails - Heroku 上的不兼容编码正则表达式匹配(ASCII-8BIT 正则表达式与 UTF-8 字符串)

我有一个Rails应用程序,我在其中使用基于正则表达式的规则对事务进行分类。在我的seeds.rb中,我创建了一些类别和规则,然后从CSV文件(也是utf8编码)导入交易并允许对它们进行分类。这个过程在我的开发机器上运行良好,但是当我在Heroku上运行它时,我得到:incompatibleencodingregexpmatch(ASCII-8BITregexpwithUTF-8string)我正在运行CedarStack,Rails2.3.15。我放了#encoding:utf-8在我所有源文件的顶部,我在我的应用程序配置中将编码设置为utf-8,所以我不确定还有什么可能导致此问题。

ruby-on-rails - 发现未经许可的参数 : utf8, authenticity_token 仅用于更新方法

我在用户管理Controller中有这样的更新方法defupdate@user.update(user_permitted_params)redirect_toadmin_user_managements_pathend我的强参数设置为defuser_permitted_paramsparams.require(:user).permit(:name,:email,:password,:password_confirmation,:address,:zip_code,:phone_number,:role_id)end我遇到了以下问题Unpermittedparameters:utf8

ruby 1.9.2 : irb throws ArgumentError: invalid byte sequence in UTF-8 when entering German Umlaut

我想在我的irb中输入德语变音符号,但出现奇怪的错误。我可以毫无问题地输入äöü的任何字符,但是每个ÄÖÜß都会导致以下错误:$irbruby-1.9.2-p136:001>?#hereIenteredÜbutitdisplaysonly?/Users/lorenz/.rvm/rubies/ruby-1.9.2-p136/lib/ruby/1.9.1/irb/ruby-lex.rb:728:in`blockinlex_int2':invalidbytesequenceinUTF-8(ArgumentError)我已经查看了很多关于Ruby、rvm和UTF-8的SO问题,但都没有帮助。大

c - 命令行错误消息的 "POSIX-defined format"是什么?哪个标准?

在ruby​​-doc.org上page我发现了以下关于命令行选项/参数解析(getopt库)的内容:ReturntheappropriateerrormessageinPOSIX-definedformat.Ifnoerrorhasoccurred,returnsnil.命令行错误消息的POSIX定义格式是什么?它是哪个POSIX标准?编辑:我必须澄清一下,我对标准/推荐的错误消息很感兴趣解析命令行参数/选项。在下面的链接(答案)中,我发现只提到了getopt的这种错误格式:"%s:illegaloption--%c\n",,"%s:optionrequiresanargument-

读取时出现 Ruby CSV UTF8 编码错误

这是我在做的:csv=CSV.open(file_name,"r")我用它来测试:line=csv.shiftwhilenotline.nil?putslineline=csv.shiftend我遇到了这个:ArgumentError:invalidbytesequenceinUTF-8我读了answerhere这就是我尝试过的csv=CSV.open(file_name,"r",encoding:"windows-1251:utf-8")我遇到了以下错误:Encoding::UndefinedConversionError:"\x98"toUTF-8inconversionfromW